草庐IT

C++ volatile 放置 新

全部标签

c++ - 对于对象图,我可以放置对象还是成对放置对象?

我使用的是C++11和gcc-4.7.0。我正在寻找STL解决方案。我想要一个未排序的multimap,其中包含以短字符串作为键的myClass对象。Emplace看起来是一种在我构建对象时将对象放入map的好方法,但我不确定它是否可以这样做,或者它是否只会构建键/对象对。这应该是有效的:table.emplace(myKey,myClass(arg1,arg2,arg3));但是执行以下操作会更有效率吗,它甚至是有效代码吗?table.emplace(myKey,arg1,arg2,arg3); 最佳答案 根据this,gcc-4

c++ - 为什么 `auto&` 不能绑定(bind)到 volatile 右值表达式?

考虑下面的代码:intmain(){inti{};auto&c=static_cast(i);//(1)auto&v=static_cast(i);//(2)}(1)编译成功,(2)不被接受:error:volatilelvaluereferencetotype'volatileint'cannotbindtoatemporaryoftype'volatileint'为什么auto不能变成volatileint?为什么auto&可以变成constint并绑定(bind)到constint&&?是因为auto&实际上绑定(bind)到一个在赋值右侧创建的临时对象吗?但是,为什么auto&

c++ - 这里是否需要 volatile

我正在实现一个“序列锁”类,以允许对数据结构进行锁定写入和无锁定读取。将包含数据的结构包含序列值,该序列值将在写入发生时递增两次。写作开始前一次,写作完成后一次。作者在读者之外的其他线程上。这是保存数据拷贝的结构,序列值如下所示:templatestructseq_data_t{seq_data_t():seq(0){};intseq;整个序列锁类在循环缓冲区中持有该结构的N个拷贝。写入线程总是覆盖循环缓冲区中最旧的数据拷贝,然后将其标记为当前拷贝。写入是互斥锁。读取功能不锁定。它尝试读取数据的“当前”拷贝。它在读取之前存储“seq”值。然后它读取数据。然后它再次读取seq值,并将其与

c++ - 为什么 volatile 不是 sig_atomic_t 的一部分

在我的平台(X86、Fedora、gcc9.1.1)上,sig_atomic_t类型定义为普通的int。在C++标准中,sig_atomic_t始终与volatile限定符一起使用。我明白为什么需要volatile,但为什么它不是类型的一部分呢?类似于:usingsig_atomic_t=volatileint; 最佳答案 这是从C继承的。C定义,同时允许sig_atomic_t要volatile合格,不需要它。我看过的标准文档(N1570)中使用的所有示例都以volatilesig_atomic_t的形式给出。.现在使用std:a

c++ - 带有 volatile 的 push_back 与 emplace_back

以下代码对push_back失败,对emplace_back成功:#includevolatileintx=0;intmain(){std::vectorvec;vec.emplace_back(x);vec.push_back(x);//error:nomatchingfunctionforcallto'std::vector::push_back(volatileint&)'}我知道push_back失败是因为它需要一个引用并试图从该引用中隐式地丢弃volatile限定符。然而,emplace_back也接受一个引用(右值引用是引用)。为什么区别对待?

c++ - volatile 在 C++ 的单线程应用程序中有用吗?

如标题所说-volatile在单线程编程的上下文中是否有用?我知道它用于确保变量的值始终在内存中实际检查,所以在任何情况下该值可能会以应用程序/编译器不会注意到的方式更改(在ST应用程序中)?我让这个问题与语言无关,因为我不知道它们之间的任何差异会影响对这个问题的回答。但如果有的话请告诉我。编辑:正如有人向我指出的那样,这个问题与语言无关。然后我将其设为特定于C++(我读到C++版本也存在差异,但我希望它们不会大到足以使这个问题过于宽泛)。 最佳答案 这是C和C++的答案是的!当变量映射到硬件寄存器(例如I/O设备)时。硬件独立于应

c++ - 直接放置在 pair 的 std::map 中

为什么这段代码无法编译?std::map>m;m.emplace(1,1,1);假设我们可以编辑std::map::emplace的代码,是否可以更改它以使之前的代码有效? 最佳答案 无效的原因与无效的原因完全相同:std::pair>p{1,1,1};因为上面本质上就是map的emplace归结为。要使其正常工作,您可以使用piecewise_constructconstructorofstd::pair,正是为了这个目的而引入的:m.emplace(std::piecewise_construct,std::forward_as

c++ - 放置新的和完美的转发

我有以下旨在创建数组的代码,但没有默认初始化其对象。我想完美地转发到placementnew,这似乎发生了,但我发现对象的析构函数在emplace函数中被调用。#include#include//std::uninitialized_copy,std::allocator...#include//std::move...#includestructInt{inti;Int():i(-1){std::coutclassNoInitArray{std::bitsetm_used;T*m_array=reinterpret_cast(::operatornew(sizeof(T)*S));p

c++ - 自 C++11 以来,volatile 在并发编程中的用处

我读过this和this回答。我还搜索了这本书C++ConcurrencyinAction并且没有找到关于volatile的讨论,也没有找到任何使用它的示例。看起来它根本不是为并发而设计的。那么对于并发编程,仅仅使用原子、互斥等就足够了,而忘记volatile吗?是否存在可能需要volatile来解决并发问题的情况? 最佳答案 不,在C++中,volatile关键字告诉编译器不得以任何方式优化变量。这在处理可以从您自己的代码外部更改的内存时非常有用,例如自定义板上的硬件寄存器。有关volatile的更深入指南,您应该阅读Volati

c++ - 如何将对象放置在结构中

创建新对象的正常方法:std::stringdate1="10/1/2010";日期d1(stringToChar(date1);但我不知道如何在结构中使用它。结构:structRecPayments{std::stringname;Datedatemake();floatcost;};尝试像这样使用它:voidaddRecurring(){//NewrecurringpaymentRecPayments*newPaymentItem=newRecPayments;//SetrecurringpaymentpropertiesnewPaymentItem->name="TestPaym